

LSI Computer Systems, Inc. 1235 Walt Whitman Road, Melville, NY 11747 (516) 271-0400 FAX (516) 271-0405

# **24-BIT DUAL-AXIS QUADRATURE COUNTER**

January 1998

#### FEATURES:

- 30 MHz count frequency in non-quadrature mode, 17MHz in X4 quadrature mode.
- Dual 24-bit counters to support X and Y axes in motion control applications
- Dual 24-bit comparators
- Digital filtering of the input quadrature clocks
- Programmable 8-bit separate filter clock prescalers for each axis
- Error flags for noise exceeding filter band width
- Programmable Index Input and other programmable I/Os.
- · Independent mode programmability for each axis
- Programmable count modes: Quadrature (X1, X2, X4) / Non-quadrature, Normal / Modulo-N / Range Limit / Non-Recycle. Binary / BCD.
- 8-bit 3-State data I/O bus
- 5V operation (VDD-Vss)
- TTL/CMOS compatible I/Os
- 28-Pin SOIC, 28-Pin PDIP (300mil, 600mil)

### **PIN ASSIGNMENT - TOP VIEW** 28-Pin Package



# LS7266R1 Registers:

LS7266R1 has a set of registers associated with each X and Y axis. All X-axis registers have the name prefix X, whereas all Y-axis registers have the prefix Y. Selection of a specific register for Read/Write is made from the decode of the three most significant bits (D7-D5) of the data-bus.  $\overline{CS}$  input enables the IC for Read/Write. C/ $\overline{D}$  input selects between control and data information for Read/Write. Following is a complete list of LS7266R1 registers.

#### Preset Registers: XPR and YPR

Each of these PRs are 24-bit wide. 24-bit data can be written into a PR, one byte at a time, in a sequence of three data write cycles.

# 0 7 HI BYTE MID BYTE

#### **Counters: XCNTR and YCNTR**

Each of these CNTRs are 24-bit synchronous Up/Down counters. The count clocks for each CNTR is derived from its associated A/B inputs. Each CNTR can be loaded with the content of its associated PR.

#### **Output Latches: XOL and YOL**

Each OL is 24-bits wide. In effect, the OLs are the output ports for the CNTRs. Data from each CNTR can be loaded into its associated OL and then read back on the data-bus, one byte at a time, in a sequence of three data Read cycles.

#### Byte Pointers: XBP and YBP

The Read and Write operations on an OL or a PR always accesses one byte at a time. The byte that is accessed is addressed by one of the BPs. At the end of every data Read or Write cycle on an OL or a PR, the associated BP is automatically incremented to address the next byte.

### Flag Register: XFLAG and YFLAG

The FLAG registers hold the status information of the CNTRs and can be read out on the data bus. The E bit of a FLAG register is set to 1 when the noise pulses at the quadrature inputs are wide enough to be validated by the input filter circuits. E = 1 indicates excessive noise at the inputs but not a definite count error. Once set, E can only be reset via the RLD.



#### Filter Clock Prescalers: XPSC and YPSC

Each PSC is an 8-bit programmable modulo-N down counter, driven by the FCK clock. The factor N is down loaded into a PSC from the associated PR low byte register PR0. The PSCs provide the ability to generate independent filter clock frequencies for each channel.

Final filter clock frequency  $f_{FCKn} = (f_{FCK}/(n+1))$ , where n = PSC = 0 to FFH

## Reset and Load Signal Decoders: XRLD and YRLD

Following functions can be performed by writing a control byte into an RLD: Transfer PR to CNTR, Transfer CNTR to OL, reset CNTR, reset FLAG and reset BP.



## Counter Mode Registers: XCMR and YCMR

The CNTR operational mode is programmed by writing into the CMRs.



#### **DEFINITIONS OF COUNT MODES:**

Range Limit. In range limit count mode, an upper and a lower limit is set, mimicking limit switches in the mechanical counterpart. The upper limit is set by the content of the PR and the lower limit is set to be 0. The CNTR freezes at CNTR=PR when counting up and at CNTR=0 when counting down. At either of these limits, the counting is resumed only when the count direction is reversed.

**Non-Recycle**. In non-recycle count mode, the CNTR is disabled, whenever a count overflow or underflow takes place. The end of cycle is marked by the generation of a Carry (in Up Count) or a Borrow (in Down Count). The CNTR is re-enabled when a reset or load operation is performed on the CNTR.

**Modulo-N.** In modulo-N count mode, a count boundary is set between 0 and the content of PR. When counting up, at CNTR=PR, the CNTR is reset to 0 and the up count is continued from that point. When counting down, at CNTR=0, the CNTR is loaded with the content of PR and down count is continued from that point.

The modulo-N is true bidirectional in that the divide-by-N output frequency is generated in both up and down direction of counting for same N and does not require the complement of N in the <u>UP instance</u>. In frequency divider application, the modulo-N output frequency can be obtained at either the Compare (FLG1) or the Borrow (FLG2) output. Modulo-N output frequency,  $f_N = (f_i / (N+1))$  where  $f_i = I_{i}$  Input count frequency and N=PR.

The information included herein is believed to be accurate and reliable. However, LSI Computer Systems, Inc. assumes no responsibilities for inaccuracies, nor for any infringements of patent rights of others which may result from its use.

# Input/Output Control Register: XIOR and YIOR

The functional modes of the programmable input and output pins are written into the IORs.



## INDEX CONTROL REGISTERS: XIDR and YIDR

Either the LCNTR/LOL or the RCNTR/ABG inputs can be initialized to operate as an index input. When initialized as such, the index signal from the encoder, applied to one of these inputs performs either the Reset CNTR or the Load CNTR or the Load OL operation synchronously with the quadrature clocks. Note that only one of these inputs can be selected as the Index input at a time and hence only one type of indexing function can be performed in any given set-up. **The index function must be disabled in non-quadrature count mode.** 



Note 1: Function selected for this pin via IOR, becomes the operating INDEX function.

Note 2: RCNTR/ABG input must also be initialized as the reset CNTR input via IOR

# **REGISTER ADDRESSING MODES**

| <b>D7</b> | D6 | D5 | C/D | RD  | WR |   | CS | FUNCTION                                            |
|-----------|----|----|-----|-----|----|---|----|-----------------------------------------------------|
| X         | X  | X  | X   | X   | X  | X | 1  | Disable both axes for Read/Write                    |
| X         | X  | X  | 0   | 1   |    | 0 | 0  | Write to XPR byte segment addressed by XBP (Note 3) |
| X         | X  | X  | 0   | 1   |    | 1 | 0  | Write to YPR byte segment addressed by YBP (Note 3) |
| 0         | 0  | 0  | 1   | 1   |    | 0 | 0  | Write to XRLD                                       |
| 0         | 0  | 0  | 1   | 1   |    | 1 | 0  | Write to YRLD                                       |
| 1         | 0  | 0  | 1   | 1   |    | X | 0  | Write to both XRLD and YRLD                         |
| 0         | 0  | 1  | 1   | 1 - |    | 0 | 0  | Write to XCMR                                       |
| 0         | 0  | 1  | 1   | 1 - |    | 1 | 0  | Write to YCMR                                       |
| 1         | 0  | 1  | 1   | 1 - |    | X | 0  | Write to both XCMR and YCMR                         |
| 0         | 1  | 0  | 1   | 1 - |    | 0 | 0  | Write to XIOR                                       |
| 0         | 1  | 0  | 1   | 1 - |    | 1 | 0  | Write to YIOR                                       |
| 1         | 1  | 0  | 1   | 1 - |    | X | 0  | Write to both XIOR and YIOR                         |
| 0         | 1  | 1  | 1   | 1 - |    | 0 | 0  | Write to XIDR                                       |
| 0         | 1  | 1  | 1   | 1 - |    | 1 | 0  | Write to YIDR                                       |
| 1         | 1  | 1  | 1   | 1 - |    | X | 0  | Write to both XIDR and YIDR                         |
| X         | X  | X  | 0   | 0   | 1  | 0 | 0  | Read XOL byte segment addressed by XBP (Note 3)     |
| X         | X  | X  | 0   | 0   | 1  | 1 | 0  | Read YOL byte segment addressed by YBP (Note 3)     |
| X         | X  | X  | 1   | 0   | 1  | 0 | 0  | Read XFLAG                                          |
| X         | X  | X  | 1   | 0   | 1  | 1 | 0  | Read YFLAG                                          |

X = Don't Care

**Note 3**: Relevant BP is automatically incremented at the trailing edge of  $\overline{RD}$  or  $\overline{WR}$  pulse

**Absolute Maximum Ratings:** 

| Parameter             | Symbol | Values         | Unit |
|-----------------------|--------|----------------|------|
| Voltage at any input  | VIN    | Vss3 to VDD+.3 | V    |
| Supply Voltage        | VDD    | +7.0           | V    |
| Operating Temperature | TA     | -25 to +80     | oC   |
| Storage Temperature   | Tstg   | -65 to +150    | oC   |

**DC Electrical Characteristics**. (TA =  $-25^{\circ}$ C to  $+80^{\circ}$ C, VDD = 4.5V to 5.5V)

| Parameter                | Symbol | Min. Value | Max.Value | Unit | Remarks        |
|--------------------------|--------|------------|-----------|------|----------------|
| Supply Voltage           | VDD    | 4.5        | 5.5       | V    | -              |
| Supply Current           | IDD    | -          | 800       | μA   | All clocks off |
| Input Logic Low          | VIL    | -          | 0.8       | V    | -              |
| Input Logic High         | Vih    | 2.0        | -         | V    | -              |
| Output Low Voltage       | Vol    | -          | 0.5       | V    | IOSNK=5mA      |
| Output High Voltage      | Voн    | VDD5       | -         | V    | IOSRC=1mA      |
| Input Leakage Current    | lilk   | -          | 30        | nA   | -              |
| Data Bus Leakage Current | IDLK   | -          | 60        | nA   | Data bus off   |
| Output Source Current    | Iosrc  | 1.0        | -         | mA   | VO = VDD5V     |
| Output Sink Current      | Iosnk  | 5.0        | -         | mA   | Vo = 0.5V      |

|                                      | Symbol        | Min. Value | Max.Value | Unit     | Remarks                                                              |
|--------------------------------------|---------------|------------|-----------|----------|----------------------------------------------------------------------|
| Read Cycle (See Fig. 1)              |               |            |           |          |                                                                      |
| RD Pulse Width                       | tr1           | 50         | -         | ns       | -                                                                    |
| CS Set-up Time                       | tr2           | 50         | -         | ns       | -                                                                    |
| CS Hold Time                         | tr3           | 0          | -         | ns       | -                                                                    |
| C/D Set-up Time                      | tr4           | 50         | -         | ns       | -                                                                    |
| C/D Hold Time                        | tr5           | 10         | -         | ns       | -                                                                    |
| X/Y Set-up Time                      | tr6           | 50         | -         | ns       | -                                                                    |
| X/Y Hold Time                        | tr7           | 10         | -         | ns       | -                                                                    |
| Data Bus Access Time                 | tr8           | 50         | -         | ns       | Access starts when both $\overline{RD}$ and $\overline{CS}$ are low. |
| Data Bus Release Time                | tr9           | -          | 25        | ns       | Release starts when either RD or CS is terminated.                   |
| Back to Back Read delay              | tr10          | 60         | -         | ns       | -                                                                    |
| Write Cycle (See Fig. 2)             |               |            |           |          |                                                                      |
| $\overline{\mathrm{WR}}$ Pulse Width | tw1           | 30         | -         | ns       | -                                                                    |
| CS Set-up Time                       | tw2           | 30         | -         | ns       | -                                                                    |
| CS Hold Time                         | twз           | 0          | -         | ns       | -                                                                    |
| C/D Set-up Time                      | tw4           | 30         | -         | ns       | -                                                                    |
| C/D Hold Time                        | tw5           | 10         | -         | ns       | -                                                                    |
| X/Y Set-up Time                      | tw6           | 30         | -         | ns       | -                                                                    |
| X/Y Hold Time                        | tw7           | 10         | _         | ns       | -                                                                    |
| Data Bus Set-up Time                 | twa           | 30         | _         | ns       | _                                                                    |
| Data Bus Hold Time                   | twe           | 10         | _         | ns       | _                                                                    |
| Back to Back Write Delay             | two           | 60         | _         | ns       | _                                                                    |
| Dack to back write belay             | LVVIO         | 00         | -         | 115      | -                                                                    |
| Quadrature Mode (See Fig. 3-         | -5)           |            |           |          |                                                                      |
| FCK High Pulse Width                 | t1            | 14         | -         | ns       | -                                                                    |
| FCK Low Pulse Width                  | t2            | 14         | -         | ns       | -                                                                    |
| FCK Frequency                        | ffck          | -          | 35        | MHz      | -                                                                    |
| Mod-n Filter Clock(FCKn)Perio        |               | 28         | -         | ns       | tз = (n+1) (t1+t2), where<br>n = PSC= 0 to FFн                       |
| FCKn frequency                       | <b>f</b> FCKn | _          | 35        | MHz      | -                                                                    |
| Quadrature Separation                | t4            | 57         | -         | ns       | t4 ≥ <b>2t</b> 3                                                     |
| Quadrature Clock Pulse Width         |               | 115        | _         | ns       | $t_5 \ge 4t_3$                                                       |
| Quadrature Clock frequency           | fqa, fqe      |            | 4.3       | MHz      | fQA = fQB = 1/8t3                                                    |
| Quadrature Clock to Count Del        |               | 5t₃        | 6t3       | -        | 1QA = 1QB = 170t3                                                    |
| X1/X2/X4 Count Clock Pulse V         | •             | 28         |           | nc       | too - to                                                             |
|                                      |               |            | -         | ns       | to2 = t3                                                             |
| Index Input Pulse Width              | tidx          | 85         | -         | ns       | $tidx \ge 3t3$                                                       |
| Index Skew from A                    | <b>t</b> Ai   | -          | 28        | ns       | tAi ≤ t3                                                             |
| Carry/Borrow/Compare Output Wi       | dth tq3       | 28         | -         | ns       | tQ3 = t3                                                             |
| Non-Quadrature Mode (See F           |               |            |           |          |                                                                      |
| Clock A - High Pulse Width           | <b>t</b> 6    | 16         | -         | ns       | -                                                                    |
| Clock A - Low Pulse Width            | <b>t</b> 7    | 16         | -         | ns       | -                                                                    |
| Direction Input B Set-up Time        | <b>t</b> 8S   | 20         | -         | ns       | -                                                                    |
| Direction Input B Hold Time          | <b>t</b> 8H   | 20         | -         | ns       | -                                                                    |
| Gate Input (ABG) Set-up Time         | tgs           | 20         | -         | ns       | -                                                                    |
| Gate Input (ABG) Hold Time           | tgн           | 20         | -         | ns       | -                                                                    |
| Clock Frequency (non-Mod-N)          | fA            | -          | 30        | MHz      | fA = (1/(t6 + t7))                                                   |
| Clock Frequency (Mod-N)              | fan           | -          | 25        | MHz      | -                                                                    |
| Clock to Carry or Borrow Out Dela    | ny t9         | _          | 30        | ns       | _                                                                    |
| Carry or Borrow Out Pulse Wig        |               | 16         | -         | ns       | t10 = t7                                                             |
| Load CNTR, Reset CNTR and            | ati 1 1 1 U   | 10         | -         | 113      | 110 – 17                                                             |
| Load OL Pulse Width                  | <b>t</b> 11   | 20         | _         | ne       | _                                                                    |
| Clock to Compare Out Delay           |               | 50<br>50   | -         | ns<br>ns | _                                                                    |
| Slock to Compare Out Delay           | <b>t</b> 12   | 30         | -         | ns       | <del>-</del>                                                         |

#### INPUTS/OUTPUTS

## X-AXIS I/Os:

**XA** (Pin 20) X-axis count input A **XB** (Pin 21) X-axis count input B

Either quadrature encoded clocks or non-quadrature clocks can be applied to XA and XB. In quadrature mode XA and XB are digitally filtered and decoded for UP/DN clock. In non-quadrature mode, the filter and the decoder circuits are by-passed. Also, in non-quadrature mode XA serves as the count input and XB as the UP/DOWN direction control input, with XB = 1 selecting Up Count mode and XB = 0, selecting Down Count mode.

# XLCNTR/XLOL

(Pin 19)

X-axis programmable input, to operate as either direct load XCNTR or direct load XOL or synchronous load XCNTR or synchronous load XOL. The synchronous load mode is intended for interfacing with the encoder Index output in quadrature clock mode. In direct load mode, a logic low level is the active level at this input. In synchronous load mode the active level can be programmed to be either logic low or logic high. Both quarter-cycle and half-cycle Index signals are supported by this input in the indexed Load mode. The synchronous function must be disabled in non-quadrature count mode (See description of IDR on P. 4)

# XRCNTR/XABG

(Pin 18)

X-axis programmable input to operate either as direct reset XCNTR or count enable/disable gate or synchronous reset XCNTR. The synchronous reset XCNTR mode is intended for interfacing with the encoder Index output in quadrature clock mode. In direct reset XCNTR mode, a logic low level is the active level at this input whereas in synchronous reset XCNTR mode the active level can be programmed to be either a logic low or a logic high. Both quarter-cycle and half-cycle index signals are supported by this input in the indexed reset CNTR mode. The synchronous function must be disabled in non-quadrature count mode (See description of IDR on P. 4). In count enable/disable mode, a logic high at this input enables the counter and a logic low level disables the counter.

XFLG1 (Pin 22) X-axis programmable output to operate either as XCARRY (Active low), or XCOMPARE (generated when XPR=XCNTR; Active low), or XIDX (XFLAG bit 6) or XCARRY/XBORROW (Active low).

X-axis programmable output to operate as either XBORROW (Active low) or XU/D (XFLAG bit 5) **XFLG2** (Pin 23) or XE (XFLAG bit 4).

#### Y-AXIS I/Os:

All the X-axis inputs/outputs are duplicated for the Y-axis with similar functionalities.

**YA** (Pin 25)

**YB** (Pin 24)

YLCNTR/YLOL (Pin 1)

YRCNTR/YABG (Pin 28)

YFLG1 (Pin 27)

YFLG2 (Pin 26)

#### COMMON I/Os:

**WR** (Pin 14) Write input. Control/data bytes are written at the trailing edge of low level pulse applied to this input.

**RD** (Pin 16) Read input. A low level applied to this input enables the FLAGs and OLs to be read on the data bus.

**CS** (Pin 15) Chip select input. A low level applied to this input enables the chip for Read and Write.

**C/D** (Pin 13) Control/Data input. This input selects between a control register or a data register for Read/Write. When low, a data register is selected. When high, a control register is selected.

D0-D7 (Pins 4-11) Data Bus input/output. The 8-bit three-state data bus is the I/O port through which all data transfers take place between the LS7266R1 and the host processor.

FCK (Pin 2) Filter clock input in quadrature mode. The FCK is divided down internally by two 8-bit programmable prescalers, one for each channel.

**X/Y** (Pin 17) Selects between X and Y axes for Read or Write.  $\overline{X}/Y = 0$  selects X-axis and  $\overline{X}/Y = 1$  selects Y-axis.  $\overline{X}/Y$  is overridden by D7 =1 in Control Write Mode (C/ $\overline{D}$  = 1).

VDD (Pin 3) +5VDC

Vss (Pin 12) GND



FIGURE 1. READ CYCLE



FIGURE 2. WRITE CYCLE



FIGURE 3. FILTER CLOCK FCK AND QUADRATURE CLOCKS A AND B

Note 4: FCKn is the final modulo-n internal filter clock, arbitrarily shown here as modulo-1.



FIGURE 4. QUADRATURE CLOCK A, B AND INDEX INPUT

- Note 5: Shown here is positive index with solid line depicting 1/4 cycle index and dotted line depicting 1/2 cycle index. Either LCNTR/LOL or RCNTR/ABG input can be used as the INDEX input.
- Note 6: X1, X2 and X4 clocks are the final internal Up/Down count clocks derived from filtered and decoded Quadrature Clock inputs, A and B.
- Note 7: IDX is the synchronized internal "load OL" or "load CNTR" or "reset CNTR" signal based on LCNTR/LOL or RCNTR/ABG input being selected as the INDEX input, respectively. This signal is identical with FLAG register bit 6.



FIGURE 5. CARRY, BORROW, COMPARE, CARRY TOGGLE, BORROW TOGGLE AND COMPARE TOGGLE IN X4 QUADRATURE, NORMAL, BINARY COUNT MODE.



FIGURE 6. COUNT (A), DIRECTION (B) AND GATE (ABG) INPUTS IN NON-QUADRATURE MODE



FIGURE 7. NON-RECYCLE, NON-QUADRATURE, BCD MODE



FIGURE 8. MODULO - N, NON-QUADRATURE (Shown with N = 3)



FIGURE 9. RANGE LIMIT, NON-QUADRATURE

(Shown with PR = 4)





FIGURE 11A. LS7266R1 INTERFACE EXAMPLES



FIGURE 11B. LS7266R1 INTERFACE EXAMPLES